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CLAIMS 



1. An apparatus for performing cryptographic operations, 
comprising : 

a cryptographic instruction, received by a computing 
device as part of an instruction flow executing 
on said computing device, wherein said 
cryptographic instruction prescribes one of the 
cryptographic operations, and wherein said 
cryptographic instruction prescribes one of a 
plurality of data block sizes; and 

execution logic, operatively coupled to said 

cryptographic instruction, configured to execute 
said one of the cryptographic operations, said 
execution logic comprising: 

a block size controller, configured to employ 

said one of a plurality of data block sizes 
during execution of said one of the 
cryptographic operations. 

2. The apparatus as recited in claim 1, wherein said one 
of the cryptographic operations further comprises: 

an encryption operation, said encryption operation 

comprising encryption of a plurality of plaintext 
blocks to generate a corresponding plurality of 
ciphertext blocks. 
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3. The apparatus as recited in claim 1, wherein said one 
of the cryptographic operations further comprises: 

a decryption operation, said decryption operation 
comprising decryption of a plurality of 
ciphertext blocks to generate a corresponding 
plurality of plaintext blocks. 

4. The apparatus as recited in claim 1, wherein said one 
of a plurality of data block sizes comprises 128 bits. 

5. The apparatus as recited in claim 1, wherein said one 
of a plurality of data block sizes comprises 192 bits. 

6. The apparatus as recited in claim 1, wherein said one 
of a plurality of data block sizes comprises 256 bits. 

7. The apparatus as recited in claim 1, wherein said one 
of the cryptographic operations is executed according 
to the Advanced Encryption Standard (AES) algorithm. 

8. The apparatus as recited in claim 1, wherein said data 
block controller is configured to interpret a data 
block size field within a control word which is 
referenced by said cryptographic instruction. 

9. The apparatus as recited in claim 1, wherein said 
cryptographic instruction is prescribed according to 
the x86 instruction format. 

10. The apparatus as recited in claim 1, wherein said 
cryptographic instruction implicitly references a 
plurality of registers within said computing device. 
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11. The apparatus as recited in claim 10 wherein said 
plurality of registers comprises: 

a first register, wherein contents of said first 
register comprise a first pointer to a first 
memory address, said first memory address 
specifying a first location in memory for access 
of a plurality of input text blocks upon which 
said one of the cryptographic operations is to be 
accomplished, said plurality of input text blocks 
are sized according to said one of a plurality of 
data block sizes. 

12. The apparatus as recited in claim 10, wherein said 
plurality of registers comprises: 

a second register, wherein contents of said second 
register comprise a second pointer to a second 
memory address, said second memory address 
specifying a second location in said memory for 
storage of a corresponding plurality of output 
text blocks, said corresponding plurality of 
output text blocks being generated as a result of 
accomplishing said one of the cryptographic 
operations upon a plurality of input text blocks, 
wherein said plurality of input and output text 
blocks are sized according to said one of a 
plurality of data block sizes. 

13. The apparatus as recited in claim 10, wherein said 
plurality of registers comprises: 
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a third register, wherein contents of said third 
register indicate a number blocks within a 
plurality of input text blocks, wherein said 
plurality of input text blocks are sized 
according to said one of a plurality of data 
block sizes. 

14. The apparatus as recited in claim 10, wherein said 
plurality of registers comprises: 

a fourth register, wherein contents of said fourth 
register comprise a third pointer to a third 
memory address, said third memory address 
specifying a third location in memory for access 
of cryptographic key data for use in 
accomplishing said one of the cryptographic 
operations . 

15. The apparatus as recited in claim 10, wherein said 
plurality of registers comprises: 

a fifth register, wherein contents of said fifth 

register comprise a fourth pointer to a fourth 
memory address, said fourth memory address 
specifying a fourth location in memory, said 
fourth location comprising said initialization 
vector location, contents of said initialization 
vector location comprising an initialization 
vector or initialization vector equivalent for 
use in accomplishing said one of the 
cryptographic operations. 
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16. The apparatus as recited in claim 8, wherein said 
plurality of registers comprises: 

a sixth register, wherein contents of said sixth 
register comprise a fifth pointer to a fifth 
memory address, said fifth memory address 
specifying a fifth location in memory for access 
of a control word for use in accomplishing said 
one of the cryptographic operations, wherein said 
control word prescribes cryptographic parameters 
for said one of the cryptographic operations, and 
wherein said control word comprises: 

a data block size field, configured to specify 

said one of a plurality of data block sizes 
to be employed during execution of said one 
of the cryptographic operations. 

17. The apparatus as recited in claim 1, wherein said 
execution logic comprises: 

a cryptography unit, configured execute a plurality of 
cryptographic rounds on each of a plurality of 
input text blocks to generate a corresponding 
each of a plurality of output text blocks, 
wherein said one of a plurality of data block 
sizes is prescribed by a control word that is 
provided to said block size controller within 
said cryptography unit . 

,18. An apparatus for performing cryptographic operations, 
comprising: 
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a cryptography unit within a device, configured to 
execute one of the cryptographic operations 
responsive to receipt of a cryptographic 
instruction within an instruction flow that 
prescribes said one of the cryptographic 
operations, wherein said cryptographic 
instruction also prescribes a block size to be 
employed when executing said one of the 
cryptographic operations; and 

block size logic, operatively coupled within said 
cryptography unit, configured to direct said 
device to employ said block size when performing 
said one of the cryptographic operations. 

19. The apparatus as recited in claim 18, wherein said 
block size comprises 128-bits. 

20. The apparatus as recited in claim 18, wherein said 
block size comprises 192-bits. 

21. The apparatus as recited in claim 18, wherein said 
block size comprises 256-bits. 

22. The apparatus as recited in claim 18, wherein said one 
of the cryptographic operations is executed according 
to the Advanced Encryption Standard (AES) algorithm. 

23. The apparatus as recited in claim 18, wherein said 
block size logic is configured to interpret a data 
block size field within a control word which is 
referenced by said cryptographic instruction. 
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24. The apparatus as recited in claim 18, wherein said 
cryptographic instruction is prescribed according to 
the x86 instruction format. 

25. A method for performing cryptographic operations in a 
device, the method comprising: 

receiving a cryptographic instruction that prescribes 
employment of particular block size during 
execution of one of a plurality of cryptographic 
operat ions ; and 

employing the data block size when executing the one 
of the cryptographic operations. 

26. The method as recited in claim 25, wherein said 
receiving comprises: 

via a field within a control word that is referenced 
by the cryptographic instruction, specifying the 
particular block size. 

27. The method as recited in claim 26, wherein said 
specifying comprises: 

prescribing 128 bits as the particular block size. 

28. The method as recited in claim 26, wherein said 
specifying comprises: 

prescribing 192 bits as the particular block size. 

29. The method as recited in claim 26, wherein said 
specifying comprises: 



DOCKET: CNTR.2 076 



71 



prescribing 256 bits as the particular block size. 

30. The method as recited in claim 25, wherein said 
employing comprises: 

executing the one of the cryptographic operations 
according to the Advanced Encryption Standard 
(AES) algorithm. 

31. The method as recited in claim 25, wherein said 
receiving comprises: 

prescribing the cryptographic instruction according to 
the x86 instruction format. 



